RISC-V-Compile

PCSource PCWR IF/ID EX/MEM

Braken

Jump/Jal\_Target

Branch\_Target ID/EX MEM/WB ID\_PCurrent WB\_PCurrent ID\_IR WB\_IR WB\_RegWrite MEM\_RegWrite EX\_RegWrite RegWrite WB\_DatatoReg DatatoReg MEM\_DatatoReg EX\_DatatoReg ID\_PCurrent EX\_Jump/Jal Jump/Jal <sup>⊥</sup>MEM\_Jump/Jal Branch\_Target Branch Main EX\_Branch MEM\_Branch Jump/Jal\_Target● EX\_WR MEM\_WR EX\_MIO MIO decoder → MEM\_MIO EX\_ALUC ImmSel → EX\_ALUS cr\_A ALUScr\_B EX\_ALUScr\_B MEM\_Target WB RegWrite MEM/WB Latcher WB\_Dat atoReg Rom\_addr rs1=ID\_IR [19:15] MWR MEM\_ALUO WB\_ALUQ Rs\_addr\_A WB\_MDR Rt\_addr\_B rdata\_A Instruction WE rs1\_data Memory MEM\_zero EX\_ALUO MEM\_ALUO **Registers** Ram\_addr Rom\_out rd=ID\_IR [11-7] Wt\_addr rdata\_B EX\_B Result Data Memory Data\_ir Data\_out Din **Dout** Wt\_data EX\_B MEM\_Datao clk • EX\_rd rd\_addr clkImmSel Imm32  $WB\_rd$ MEM\_rd **CPU ID\_IR** [31:20][19:12][11:7] WB\_WData flush reserve (Data Hazard)

EXE\_Stage

MEM\_Stage

WB\_Stage

ID\_Stage

IF\_Stage